

# Aula 1 - Lógica programável Introdução FPGA

Rafael Corsi Ferrão - IMT

rafael.corsi@maua.br
http://www.maua.br

6 de outubro de 2014

### Conteúdo

Introdução FPGA O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

- 1 Introdução FPGA
  - O que é FPGA ?
  - Aplicações
- 2 História
- 3 FPGA Arquitetura interna
  - Visão Geral
  - CLB
  - Matriz de roteamento
  - Memory-Blocks
  - IO-Blocks
  - IO Blocs
  - Sinais Globais
  - Revisão



### Conteúdo

#### Introdução FPGA

O que é FPGA ? Aplicações

#### História.

Revisão

FPGA - Arquitetura

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

- 1 Introdução FPGA
  - O que é FPGA?
  - Aplicações
- 2 História
- 3 FPGA Arquitetura interna
  - Visão Geral
  - CLB
  - Matriz de roteamento
  - Memory-Blocks
  - IO-Blocks
  - IO Blocs
  - Sinais Globais
  - Revisão



# O que é FPGA ? Field-programmable gate array

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão



Figura: Nexys 4



# Não é um processador!

Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral CLB

Matriz de roteamento Memory-Blocks

Memory-Blocks IO-Blocks

IO Blocs

Sinais Globais



Figura: (2008) Digital Systems Design with FPGAs and CPLDs - pg. 41



# Mas podemos implementar um... Complex Programmable Logic Device

Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral CLB Matriz de roteamento Memory-Blocks IO-Blocks

Memory-Blocks IO-Blocks IO Blocs Sinais Globais Revisão



Figura: Nios Altera



#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

# Então o que é ?

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

- é um dispositivo realmente capaz de executar processos em paralelo
- é um hardware altamente configurável
- o mais próximo de ASIC que podemos chegar

### A onde é usado ?

#### Introdução FPGA

O que é FPGA ?

#### Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral CLB Matriz de roteamento

Matriz de roteamen Memory-Blocks IO-Blocks IO Blocs

Sinais Globais Revisão

- Militar
- Aerospacial
- Médica
- Comunicação (roteadores/ modens)



# Aplicações

#### Introdução FPGA

O que é FPGA ?

#### Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral CLB Matriz de roteamento

Memory-Blocks
IO-Blocks
IO Blocs

Sinais Globais Revisão

- Imageamento
- Criptografia
- Modulação
- Processamento de dados
- Internet
- Protocolos de alta velocidade



### Mercado

Introdução FPGA O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

O mercado de FPGA gira em torno de \$20 bilhões de dolares por ano, sendo os principais fabricantes:





### Desenvolvimento

#### Introdução FPGA

O que é FPGA ?

#### Aplicações

Hist ória

#### FPGA - Arquitetura interna

Visão Geral CLB Matriz de roteamento

Memory-Blocks

IO-Blocks IO Blocs

Sinais Globais





## Conteúdo

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

Revisão

FPGA - Arquitetura

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

- 1 Introdução FPGA
  - O que é FPGA?
  - Aplicações
- 2 História
- 3 FPGA Arquitetura interna
  - Visão Geral
  - CLB
  - Matriz de roteamento
  - Memory-Blocks
  - IO-Blocks
  - IO Blocs
  - Sinais Globais
  - Revisão



# Tudo começou com os PLDs - Programmable Logic Device

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

■ Introduzido em 1970 pela Philips.





# Que evoluiu para os CPLDs Complex Programmable Logic Device

Introdução FPGA O que é FPGA ? Aplicações

# Hist ória

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

Que é um conjunto de PLDs interconectado por uma matriz de roteamento.





#### Introdução FPGA

O que é FPGA ? Aplicações

### Hist ória

Revisão

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais





### Conteúdo

Introdução FPGA O que é FPGA ? Aplicações

#### Hist ória

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

- 1 Introdução FPGA
  - O que é FPGA?
  - Aplicações
- 2 História
- 3 FPGA Arquitetura interna
  - Visão Geral
  - CLB
  - Matriz de roteamento
  - Memory-Blocks
  - IO-Blocks
  - IO Blocs
  - Sinais Globais
  - Revisão



# Que então, chegou na FPGA

Introdução FPGA O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna Visão Geral

VISAO GERAI
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

Uma arquitetura similar porém com blocos lógicos (diferente de PLDs) e alocado de forma mais distribuído na pastilha. O que permite a implementação de uma gama maior de lógicas.





# Arquitetura interna

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral CLB

CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais
Revisão

Os principais blocos internos de uma FPGA são:

- Logic-Blocks
- Switch Matrix
- Memory-Blocks
- IO-Blocks
- Sinais globais



# Commum Logic Block - CLB

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral

Revisão

CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

O CLBs é a unidade mais básica da FPGA, cada fabricante utiliza um nome diferente para os CLBs:

■ logic cell, slice, macrocell e logic element



# Commum Logic Block - CLB

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

FPGA - Arquitetura

### Visão Geral

CLB Matriz de roteamento

Memory-Blocks 10-Blocks 10 Blocs Sinais Globais Revisão

# Cada CLB possui internamente

- LUT Look-Up-Table
- Multiplexadores
- Flip-Flops
- Somador



■ A estrutura interna do CLB é dependente do fabricante e família da FPGA utilizada.



# LUT - Look Up Table

Introdução FPGA O que é FPGA ? Aplicações

### História

# FPGA - Arquitetura

#### Visão Geral CLB

Revisão

Matriz de roteamento Memory-Blocks IO-Blocks IO Blocs Sinais Globais

- Implementa-se utilizando uma memória qualquer tabela verdade
- as entradas atuam como endereço para acessar a resposta que está salvo na memória
- Exemplo: [(A.C) + (B.C)].D = z



| _ |   |   |   |   |
|---|---|---|---|---|
| D | С | В | Α | Z |
| 0 | 0 | 0 | 0 | 0 |
| 0 | 0 | 0 | 1 | 0 |
| 0 | 0 | 1 | 0 | 0 |
| l | • | • | • |   |
| 1 | 0 | 0 | 1 | 1 |
| 1 | 0 | 1 | 0 | 0 |
| 1 | 0 | 1 | 1 | 0 |
| 1 | 1 | 0 | 0 | 0 |
| 1 | 1 | 0 | 1 | 1 |
| 1 | 1 | 1 | 0 | 0 |
| 1 | 1 | 1 | 1 | 1 |

# Multiplexiador (Mux)

Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral

CLB

Matriz de roteamento Memory-Blocks IO-Blocks

IO Blocs Sinais Globais Revisão

■ Sistema digital ou analógico que escolhe dentre um entrada uma única saída



| in 1 | in 2 | in2 | Addr | ou. |
|------|------|-----|------|-----|
| D1   | D2   | D3  | 0x00 | D1  |
| D1   | D2   | D3  | 0x01 | D2  |
|      |      |     |      |     |



# Flip Flop - Unidade básica de memória

#### Introdução FPGA O que é FPGA ?

O que é FPGA ! Aplicações

### História

# FPGA - Arquitetura interna

#### Visão Geral CLB

Matriz de roteamento Memory-Blocks

Memory-Blocks IO-Blocks IO Blocs Sinais Globais Revisão

- O flip-flop é um dos elementos mais básicos de memória
- é um elemento síncrono, ou seja, necessita de um clock
- os mais utilizados em CLB é o tipo Q



Tabela verdade Flip flop tipo D

Rst

| U | 1 | _ | _  | 1 |  |
|---|---|---|----|---|--|
| 1 | 0 | - | -  | 0 |  |
| 0 | 0 | - | -  | _ |  |
| 1 | 1 | 1 | LH | 1 |  |
| 1 | 1 | 0 | ΙH | 0 |  |



Set

## Somador

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

FPGA - Arquitetura interna

### Visão Geral

Revisão

CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

- Unidade capaz de executar soma
- o tamanho dos dados a serem somados dependem da família da FPGA
- o carry é compartilhado para outros CLBs



# Somador - Carry

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral

CLB

### Matriz de roteamento Memory-Blocks

IO-Blocks IO Blocs Sinais Globais Revisão





# Exemplo CLB - Altera Stratix 4

Combinational/Memory ALUT0

Combinational/Memory ALUT1

shared arith out

shared arith in

dataf0

Introdução FPGA

O que é FPGA ? Aplicações

História

FPGA - Arquitetura interna

CLB

Matriz de roteamento Memory-Blocks IO-Blocks IO Blocs

local routing Visão Geral datae0 6-Input LUT To general or adder0 local routing dataa ∣ reg0 datab Sinais Globais Revisão datac To general or datad adder1 local routing 6-Input LUT datae1 reg1 dataf1 To general or local routing

carry\_in

carry\_out



reg\_chain\_out

reg\_chain\_in

labclk

To general or

# CLB - Altera Stratix 4

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

# FPGA - Arquitetura interna

#### Visão Geral

CLB Matriz de roteamento

Matriz de roteame Memory-Blocks

IO-Blocks

IO Blocs Sinais Globais





### Matriz de roteamento

### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral CLB

#### CLB Matriz de roteamento

Memory-Blocks IO-Blocks IO Blocs Sinais Globais Revisão

- A matriz de roteamento é responsável por interligar os CLB
- São programadas na inicialização e não podem mudar durante operação
  - Nova tecnologia chamada de Partial reconfiguration permite a reprogramação em operação.
- é análogo ao roteamento de um PCB



### Matriz de roteamento

#### Introdução FPGA

O que é FPGA ? Aplicações

Hist ória

# FPGA - Arquitetura interna

Visão Geral CLB

#### Matriz de roteamento

#### Memory-Blocks

IO-Blocks

IO Blocs

Sinais Globais





### Matriz de roteamento

#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

# FPGA - Arquitetura interna

Visão Geral CLB

#### Matriz de roteamento

Memory-Blocks IO-Blocks IO Blocs

Sinais Globais





# Memory- Blocks

Introdução FPGA O que é FPGA ? Aplicações

FPGA - Arquitetura interna

Visão Geral CLB

Matriz de roteamento

Memory-Blocks

IO-Blocks

IO Blocs Sinais Globais

Revisão

São blocos de memória compartilhada na FPGA

nota: é possível também implementar o chamado memória distribuída, onde utiliza-se de FF no lugar de blocos dedicados

- do tido RAM ou ROM
- comporta-se similar a uma memória ram convencional, onde os tempos de acesso necessitam ser respeitados
- podem ser do tipo: Single-Port, Dual-Port



## IO Blocs

Introdução FPGA O que é FPGA ? Aplicações

----

FPGA - Arquitetura interna Visão Geral

CLB Matriz de roteamento

Memory-Blocks I**O-Blocks** 

IO Blocs

Sinais Globais Revisão Uma da principal característica da FPGA é a flexibilidade com os seus I/Os, tanto no mapeamento (place) quanto na escolha do nível de sinal (CMOS, TTL ...).

Além do nível de sinal, pode-se escolher entre uma enorme gama de periféricos dedicados:

- Serializador / Desearializador
- acesso a memória DDR2/3
- PICe / PCI
- ethernet



### 10 Blocs

Introdução FPGA O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna Visão Geral

CLB Matriz de roteamento Memory-Blocks

10-Blocks

Sinais Globais Revisão

# Similar ao microprocessador, também utiliza de Bancos de IO (IO Banks)

Table 1-1: Supported Features in the HR and HP I/O Banks

| Feature                                                | HP I/O Banks             | HR I/O Banks |
|--------------------------------------------------------|--------------------------|--------------|
| 3.3V I/O standards <sup>(1)</sup>                      | N/A                      | Supported    |
| 2.5V I/O standards <sup>(1)</sup>                      | N/A                      | Supported    |
| 1.8V I/O standards <sup>(1)</sup>                      | Supported                | Supported    |
| 1.5V I/O standards <sup>(1)</sup>                      | Supported                | Supported    |
| 1.35V I/O standards <sup>(1)</sup>                     | Supported                | Supported    |
| 1.2V I/O standards <sup>(1)</sup>                      | Supported                | Supported    |
| LVDS signaling                                         | Supported <sup>(2)</sup> | Supported    |
| 24 mA drive option for LVCMOS18 and LVTTL outputs      | N/A                      | Supported    |
| V <sub>CCAUX_IO</sub> supply rail                      | Supported                | N/A          |
| Digitally-controlled impedance (DCI) and DCI cascading | Supported                | N/A          |
| Internal V <sub>REF</sub>                              | Supported                | Supported    |



### Sinais Globais

Introdução FPGA O que é FPGA ? Aplicações

História

FPGA - Arquitetura interna Visão Geral

CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks

Sinais Globais Revisão Internamente na FPGA existem sinais globais, que não passam pelas matrizes de roteamento e possuem uma utilização e projeto bem específico, os principais sinais globais são:

- Clock
- Reset

Podemos ter na FPGA diversos sinais de clock e reset independentes, porém cada um deve ser mapeado em um sinal global.



### Sinais Globais

Introdução FPGA O que é FPGA ?

Aplicações

TISCOTIA

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs

Sinais Globais Revisão Sinais de clock devem se acessados de forma especifica, pois como operam em grande velocidade possuem todos os problemas de EMC/EMI e se comportam como uma linha de transmissão (microstrip)

Regiões de clock variam de 4 em dispositivos menores para 24 nos maiores dispositivos.



### Revisão

Introdução FPGA O que é FPGA ? Aplicações

Hist ória

FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais





#### Introdução FPGA

O que é FPGA ? Aplicações

#### Hist ória

# FPGA - Arquitetura interna

Visão Geral
CLB
Matriz de roteamento
Memory-Blocks
IO-Blocks
IO Blocs
Sinais Globais

